查看原文
其他

JKD16正式发布新,特新一览(文末送书)

L IT服务圈儿 2022-09-10

作者丨L

来源丨经授权转自 苦味代码

JDK16已于北美时间3月16日发布,对Java开发者来说,JDK的这次更新总共带来了12个全新的特性

1. 支持类型匹配的instanceof

if (obj instanceof String) {
    String s = (String) obj;    // grr...
    ...
}

这样的类型转换在JDK16中的写法是:

if (obj instanceof String s) {
    // Let pattern matching do the work!
    // varialble s can be used here
    ...
}

如果obj的真实类型是String,则变量s可以在if语句中使用,但是如果obj的类型不是String,则s不能用在后续的变量命名中:

// a is not instance of Point
if (a instanceof Point p) {
   ...
}
if (b instanceof Point p) {         // ERROR - p is in scope
   ...
}

2. record关键字

对于一些POJO类,我们往往需要这样写

class Point {
    private final int x;
    private final int y;

    Point(int x, int y) {
        this.x = x;
        this.y = y;
    }

    int x() return x; }
    int y() return y; }

    public boolean equals(Object o) {
        if (!(o instanceof Point)) return false;
        Point other = (Point) o;
        return other.x == x && other.y == y;
    }

    public int hashCode() {
        return Objects.hash(x, y);
    }

    public String toString() {
        return String.format("Point[x=%d, y=%d]", x, y);
    }
}

在引入了record关键字之后,上面的代码可以简化为:

record Point(int x, int y) { }

如果对类的属性初始化的时候有定制逻辑,也是支持的

record Rational(int num, int denom) {
    Rational {
        int gcd = gcd(num, denom);
        num /= gcd;
        denom /= gcd;
    }
}

3.全并发的ZGC

与CMS中的ParNew和G1类似,ZGC也采用标记-复制算法,不过ZGC对该算法做了重大改进:ZGC在标记、转移和重定位阶段几乎都是并发的,这是ZGC实现停顿时间小于10ms目标的最关键原因。

ZGC只有三个STW阶段:初始标记,再标记,初始转移。其中,初始标记和初始转移分别都只需要扫描所有GC Roots,其处理时间和GC Roots的数量成正比,一般情况耗时非常短;再标记阶段STW时间很短,最多1ms,超过1ms则再次进入并发标记阶段。即,ZGC几乎所有暂停都只依赖于GC Roots集合大小,停顿时间不会随着堆的大小或者活跃对象的大小而增加。与ZGC对比,G1的转移阶段完全STW的,且停顿时间随存活对象的大小增加而增加。

4. 可弹性伸缩的元数据区

JDK16对元数据区切分为更小的内存块,并将不再使用的内存快速返还给操作系统,对于频繁加载和卸载类的应用来说这一优化可以产生大量的空闲内存,提升整个JVM的性能

5. 支持Unix套接字

在2019 Windows Server和Windows 10提供了对Unix套接字的支持,Unix套接字常用于本地进程之间通信,相比于TCP协议,本地进程使用Unix套接字可以更高效安全的通信。JDK16新增了一个适配Unix套接字的新接口java.net.UnixDomainSocketAddress用于支持这一特性

6. 新的打包工具jpackage

支持将Java程序打包为对应平台的可执行程序

  • linux: deb和rpm
  • mac: pkg和dmg
  • Windows: msi和exe 假如我们在lib目录下有一个jar包组成的应用,并且main.jar包含main方法,则可以使用下面的语句产生对应平台的可执行程序
jpackage --name myapp --input lib --main-jar main.jar

如果main.jar的MANIFEST.MF没有指定main函数,则需要在命令行中指定

jpackage --name myapp --input lib --main-jar main.jar \
  --main-class myapp.Main

7. 针对Value-Based类的编译器warning提示

对于基本类型的包装类,JDK16提供了两种新的编译器warning提示

  • 包装类的构造函数在JDK9已经被废弃,如果在程序中继续使用,则编译器会报warning提示
  • 如果包装类作为关键字synchronized的参数使用,则也会收到编译器的warning提示
  • 如果接口类作为关键字synchronized的参数使用,则会收到javac编译器的warning提示 举例:
Double d = 20.0;
synchronized (d) { ... } // javac warning & HotSpot warning
Object o = d;
synchronized (o) { ... } // HotSpot warning

8. 对JDK内部方法提供强制的封装

这个更新目的是为了引导开发者放弃使用JDK内部类转为使标准的API接口,除了例如sun.misc.Unsafe这样内部关键的接口之外,其他所有内部元素都提供默认的封装。使用了JDK内部接口的代码再JDK16下编译会失败,JVM参数-–illegal-access能够控制这一行为,要知道从JDK9到JDK15,这个参数默认的值都是warning,而现在已经变成了deny

9. 提供向量计算的API

之前向量计算的API在JDK中是缺失的,常见的二方库有coltcommons-math3,这些二方库在版本老旧,在易用性上也比较差,此次JDK16引入的向量计算的API针对多数现代CPU使用的SIMD指令进行了优化,大幅提升了计算性能

10. 对原生代码的调用提供更方便的支持

相比于JNI,提供更方便的方法用于调用原生代码,比如我们想在Java代码中调用size_t strlen(const char *s);这个原生C函数,我们只需要这样写:

MethodHandle strlen = CLinker.getInstance().downcallHandle(
        LibraryLookup.ofDefault().lookup("strlen"),
        MethodType.methodType(long.class, MemoryAddress.class),
        FunctionDescriptor.of(C_LONG, C_POINTER)
    )
;

11. 提供操作外部内存的能力

JDK16通过VarHandle这个类的实例来引用外部内存区域,如果我们想初始化一段外部的内存区域,可以这样写:

VarHandle intHandle = MemoryHandles.varHandle(int.class,
        ByteOrder.nativeOrder())
;

try (MemorySegment segment = MemorySegment.allocateNative(100)) {
    for (int i = 0; i < 25; i++) {
        intHandle.set(segment, i * 4, i);
    }
}

12. 提供限制可以继承此类的关键字sealedpermits

在JDK16中,提供了一种比访问修饰符更精细的控制手段:可以指定可以继承或者实现当前类或者接口的类,这个能力是通过关键字sealedpermits实现的

public abstract sealed class Shape 
    permits com.example.polar.Circle,
            com.example.quad.Rectangle,
            com.example.quad.simple.Square 
{ ... }

比如在上面的这个例子中,类Shape只能限定被Circle,RectangleSquare继承。


送书


👇👇👇留言的朋友均有机会获得书籍呦~
今日书单 | 包邮送推荐理由:从本书介绍了应用智能运维系统建设涉及的技术、工具、流程、方法,系统地总结了应用智能运维系统的演进过程,对比了市场主流的应用运维产品,分析了关键智能化应用运维技术、相关开源软件工具的能力和真实行业用户建设案例。
另外,本书通过提炼、总结大量不同行业用户建设应用智能运维系统的典型应用场景,全面透彻地介绍了相关项目的规划、开发、实施过程,对企业应对未来数字信息时代应用运维场景下智能运维系统的建设和改造有较高的参考价值。 


活动规则:


我们将从精选留言中随机抽取 6名 伙伴赠书,中奖者可在上方书单中任选一本图书,我们包邮赠送。书籍有限,中奖后先选先得。


  • 《应用智能运维实践》 *6


小锦鲤玩法:

  • 本次小锦鲤我们将从精选留言中随机抽取 2~5名 小锦鲤,赠送红包 6.6元


开奖后圈儿会给中奖者发送留言,请大家凭留言截图添加圈儿微信号:jb_quaner领取


留言要求:

  • 内容与本文核心信息相关

  • 留想要的书籍名称

  • 每人仅限精选一条留言(用心留言更容易上墙)

  • 为了大家都有机会中奖,每个小伙伴每个星期只能中一次奖哦~


截止时间: 2021 年 3 月 21 日 16:00 整

兑奖时效:一周,收到留言请尽快联系圈儿。


每天 17:30 不见不散!


1、牛逼坏了!牙医教你用450行代码写出一个编程语言

2、谷歌又一明星项目宣告失败:烧了数千万美元,150名开发者全部遣散

3、为什么人脸识别系统总是认错黑人?

4、很痛心,又有一款国内网盘或将面临倒闭!

识别关注我们

了解更多精彩内容

点分享

点点赞

点在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存